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Field of the Invention 

The invention relates generally to Internet browsers. More particularly, the 
invention relates to Internet appliances using a single window environment. 

15 

Background 

Internet appliances have become an increasingly popular tool for accessing the 
Internet. For some consumers who are only interested in browsing the Internet and 
communicating electronic mail (e-mail), Internet appliances offer a low-cost alternative 
20 to relatively expensive personal computers. This option also appeals to users who 
already own a personal computer and want a secondary device for Internet access, for 
example, from a different location in the home. For many users for whom personal 
computers can be intimidating, Internet appliances offer a relatively simple to use 
alternative. 

25 One feature of Internet appliances that enhances ease of use is a single window 

environment. In such an environment, the user is presented with a single full screen 
browser window, as contrasted with the multiple window environment presented by other 
conventional Internet browsers. The single, full-screen window environment allows the 
user to begin using the system quickly without first having to learn about window 

30 manipulation, e.g., positioning and sizing of windows. 



While a single window environment simplifies use, it also presents limitations 
that impair usability in certain circumstances. For example, standard HTML allows a 
web developer to cause new browser windows to pop up, breaking this simplified user 
model. This feature can be used to open new browser windows either in response to 
5 some action on the part of the user, or without such user action. For example, a web 
developer can cause a pop-up advertisement to appear upon loading (entering) or 
unloading (exiting) a web page. On the other hand, certain applications, such as web- 
based e-mail, open new browser windows in response to user input, e.g., clicking on an 
"address book" link. 

1 0 Many conventional Internet appliances that use a single window environment 

simply ignore all requests to open new browser windows in order to preserve the single 
window interface. This approach, however, leaves the user with a degraded experience 
of the web in which many pages that are critical to performing useful tasks do not appear. 
Accordingly, a need continues to exist for causing such pages to appear, while 

1 5 maintaining the simplicity of a single window environment. 

Summary of the Invention 

According to various implementations of the present invention, a request to open 
a new browser window is either allowed or ignored, depending on whether the request 

20 was generated in response to user input. If the request was not generated in response to 
user input, as is the case with pop-up advertisements, the request is ignored. If, on the 
other hand, the request was generated in response to user input, it is more likely to be 
important for performing some useful task, and is allowed. In such cases, in order to 
preserve the single window interface, the new browser window is opened as a full screen 

25 window that overlays the existing browser window. In certain implementations, the 
determination of whether or not a request was generated in response to user input is 
simplified by assuming that all requests that are generated during the loading or 
unloading of a page are not in response to user input and ought to be ignored. By 
contrast, window open requests that are generated at other times are assumed to be user- 

30 initiated and are allowed. 
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In one embodiment, a request to open a second browser window is received while 
a first browser window is displayed. The request is ignored if it was not initiated in 
response to a user action. The second browser window is opened if the request was 
initiated in response to a user action. 
5 In an alternative embodiment, the request is ignored if it was initiated during 

either loading or unloading of a page in the first browser window, and the second browser 
window is opened if the request was initiated after loading and before unloading of a 
page in the first browser window. 

Still other implementations include computer-readable media and apparatuses for 
10 performing the above-described methods. The above summary of the present invention is 
not intended to describe every implementation of the present invention. The figures and 
the detailed description that follow more particularly exemplify these implementations. 

Brief Description of the Drawings 

illustrates a simplified overview of an example embodiment of a 
computing environment for the present invention, 
is a flowchart depicting an example method for processing a 
request to open a new browser instance, according to a particular 
embodiment of the present invention 

conceptually depicts an example series of navigation operations 
and the manner in which they are handled according to an 
operational example of the present invention. 

25 

Detailed Description 

In the following detailed description of various embodiments, reference is made 
to the accompanying drawings that form a part hereof, and in which are shown by way of 
illustration specific embodiments in which the invention may be practiced. It is 
30 understood that other embodiments may be utilized and structural changes may be made 
without departing from the scope of the present invention. 

3 



15 Figure 1 

Figure 2 

20 Figure 3 



Hardware and Operating Environment 
Figure 1 illustrates a hardware and operating environment in conjunction with 
which embodiments of the invention may be practiced. The description of Figure 1 is 
5 intended to provide a brief, general description of suitable computer hardware and a 
suitable computing environment with which the invention may be implemented. 
Although not required, the invention is described in the general context of computer- 
executable instructions, such as program modules, being executed by a computer, such as 
a personal computer (PC). This is one embodiment of many different computer 

10 configurations, some including specialized hardware circuits to analyze performance, that 
may be used to implement the present invention. Generally, program modules include 
routines, programs, objects, components, data structures, etc. that perform particular tasks 
or implement particular abstract data types. 

Moreover, those skilled in the art will appreciate that the invention may be 

15 practiced with other computer system configurations, including hand-held devices, 

multiprocessor systems, microprocessor-based or programmable consumer electronics, 
network personal computers (PCs), minicomputers, mainframe computers, and the like. 
The invention may also be practiced in distributed computing environments where tasks 
are performed by remote processing devices linked through a communications network. 

20 In a distributed computing environment, program modules may be located in both local 
and remote memory storage devices. 

Figure 1 shows a computer arrangement implemented as a general purpose 
computing or information handling system 80, This embodiment includes a general 
purpose computing device, such as a personal computer (PC) 120, that includes a 

25 processing unit 121, a system memory 122, and a system bus 123 that operatively couples 
the system memory 122 and other system components to the processing unit 121. There 
may be only one or there may be more than one processing unit 121, such that the 
personal computer 120 comprises a single central processing unit (CPU), or a plurality of 
processing units, commonly referred to as a parallel processing environment. The 

30 computer 120 may be a conventional computer, a distributed computer, or any other type 
of computer; the invention is not so limited. 
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In other embodiments, other configurations are used in the personal computer 
120. The system bus 123 may be any of several types, including a memory bus or 
memory controller, a peripheral bus, and a local bus, and may use any of a variety of bus 
architectures. The system memory 122 may also be referred to simply as the memory, 
5 and it includes a read only memory (ROM) 124 and a random access memory (RAM) 
125. A basic input/output system (BIOS) 126 stored in the ROM 124, contains the basic 
routines that transfer information between components of the personal computer 120. 
The BIOS 126 also contains start-up routines for the system. 

The personal computer 120 typically includes at least some form of computer- 

1 0 readable media. Computer-readable media can be any available media that can be 
accessed by the personal computer 120. By way of example, and not limitation, 
computer-readable media may comprise computer storage media and communication 
media. Computer storage media includes volatile and nonvolatile, removable and non- 
removable media implemented in any method or technology for storage of information 

15 such as computer readable instructions, data structures, program modules, or other data. 
Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash 
memory or other memory technology, CD-ROM, digital versatile discs (DVD) or other 
optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other 
magnetic storage devices, or any other medium that can be used to store the desired 

20 information and that can be accessed by the personal computer 120. Communication 
media typically embodies computer readable instructions, data structures, program 
modules, or other data in a modulated data signal such as a carrier wave or other transport 
mechanism and includes any information delivery media. The term "modulated data 
signal" means a signal that has one or more of its characteristics set or changed in such a 

25 manner as to encode information in the signal. By way of example, and not limitation, 
communication media includes wired media such as a wired network or direct-wired 
connection, and wireless media such as acoustic, RF, infrared, and other wireless media. 
Combinations of any of the above are also included in the scope of computer readable 
media, 

30 By way of example, the particular system depicted in Figure 1 further includes a 

hard disk drive 127 having one or more magnetic hard disks (not shown) onto which data 
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is stored and retrieved for reading from and writing to a hard disk interface 132, a 
magnetic disk drive 128 for reading from and writing to a removable magnetic disk 129, 
and an optical disk drive 130 for reading from and/or writing to a removable optical disk 
131, such as a CD-ROM, DVD, or other optical medium. The hard disk drive 127, 
5 magnetic disk drive 128, and optical disk drive 130 are connected to the system bus 123 
by a hard disk drive interface 132, a magnetic disk drive interface 133, and an optical 
drive interface 134, respectively. The drives 127, 128, and 130 and their associated 
computer readable media 129, 131 provide nonvolatile storage of computer-readable 
instructions, data structures, program modules, and other data for the personal computer 
10 120. 

In various embodiments, program modules are stored on the hard disk drive 127, 
the magnetic disk 1 29, the optical disk 131, ROM 1 24, and/or RAM 1 25 and may be 
moved among these devices, e.g., from the hard disk drive 127 to RAM 125. Program 
modules include an operating system 135, one or more application programs 136, other 

15 program modules 137, and/or program data 138. A user may enter commands and 

information into the personal computer 120 through input devices such as a keyboard 140 
and a pointing device 42, Other input devices (not shown) for various embodiments 
include one or more devices selected from a microphone, joystick, game pad, satellite 
dish, scanner, or the like. These and other input devices are often connected to the 

20 processing unit 121 through a serial port interface 146 coupled to the system bus 123, but 
in other embodiments they are connected through other interfaces not shown in Figure 1, 
such as a parallel port, a game port, or a universal serial bus (USB) interface. A monitor 
147 or other display device also connects to the system bus 123 via an interface such as a 
video adapter 148. In some embodiments, one or more speakers 157 or other audio input 

25 transducers are driven by a sound adapter 156 connected to the system bus 123. In some 
embodiments, in addition to the monitor 147, the system 80 includes other peripheral 
output devices (not shown), such as a printer or the like. 

In some embodiments, the personal computer 120 operates in a networked 
environment using logical connections to one or more remote computers such as a remote 

30 computer 149, The remote computer 149 may be another personal computer, a server, a 
router, a network PC, a peer device, or other common network node. The remote 
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computer 149 typically includes many or all of the components described above in 
connection with the personal computer 120; however, only a storage device 150 is 
illustrated in Figure 1 . The logical connections depicted in Figure 1 include a local area 
network (LAN) 151 and a wide area network (WAN) 152, both of which are shown 
5 connecting the personal computer 120 to the remote computer 149. Typical 

embodiments would only include one or the other. Such networking environments are 
commonplace in offices, enterprise-wide computer networks, intranets, and the Internet. 

When placed in a LAN networking environment, the personal computer 120 
connects to the local network 151 through a network interface or adapter 133. When 

10 used in a WAN networking environment, such as the Internet, the personal computer 120 
typically includes a modem 154 or other means for establishing communications over the 
network 152. The modem 154 may be internal or external to the personal computer 120 
and connects to the system bus 123 via the serial port interface 146 in the embodiment 
shown. In a networked environment, program modules depicted as residing within the 

1 5 personal computer 120 or portions thereof may be stored in the remote storage device 
150. Of course, the network connections shown are illustrative, and other means 
establishing a communications link between the computers may be substituted. 

Software may be designed using many different methods, including object- 
oriented programming methods. C++ and Java are two examples of common object- 

20 oriented computer programming languages that provide functionality associated with 

object-oriented programming. Object-oriented programming methods provide a means to 
encapsulate data members (variables) and member functions (methods) that operate on 
that data into a single entity called a class. Object-oriented programming methods also 
provide means to create new classes based on existing classes. 

25 An object is an instance of a class. The data members of an object are attributes 

that are stored inside the computer memory, and the methods are executable computer 
code that act upon this data, along with potentially providing other services. The notion 
of an object is exploited in the present invention in that certain aspects of invention are 
implemented as objects in some embodiments. 

30 An interface is a group of related functions that are organized into a named unit. 

Some identifier may uniquely identify each interface. Interfaces have no instantiation; 
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that is, an interface is a definition only without the executable code needed to implement 
the methods that are specified by the interface. An object may support an interface by 
providing executable code for the methods specified by the interface. The executable 
code supplied by the object must comply with the definitions specified by the interface. 
5 The object may also provide additional methods. Those skilled in the art will recognize 
that interfaces are not limited to use in or by an object-oriented programming 
environment. 

Example Embodiments 

10 According to an embodiment of the present invention, an Internet appliance uses a 

single-window interface to interact with the user. Rather than simply ignoring all 
requests to open new browser windows, the Internet appliance selectively responds to 
some such requests by opening new browser windows, while ignoring other requests. 
The decision of whether to process or ignore a request for a new browser window is 

1 5 informed by whether the request was initiated by the user or not. In a particular 
embodiment, this determination is approximated by an assumption that a request 
occurring during the loading or unloading of a page was not user-initiated, and ought to 
be ignored. By contrast, requests occurring at other times are assumed to be user- 
initiated, and are processed. In another embodiment, instead of relying on these 

20 assumptions, the Internet appliance is configured to determine whether a request to open 
a new browser window was user-initiated. The Internet appliance opens new browser 
windows as full-screen windows in order to preserve the appearance of a single window 
interface. 

A request to open a new browser window can occur in response to a variety of 
25 events. For example, there may be script on a page that calls a window.openQ function, 
which normally causes a new browser window to be opened. Browser open requests can 
also occur, for example, in response to anchors in a page that have a TARGET- 'x" 
attribute, where x defines a frame that is not yet defined. 

When either of these mechanisms is used to create a new browser window, the 
30 system honors the request by creating a new browser instance that navigates to the new 
page. The new browser instance appears directly above the existing browser window and 
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has the same dimensions as the existing browser window. That is, all window sizing 
commands are ignored when opening the new browser instance - the new browser 
instance is always opened as a full-screen window. With the new browser instance 
having the same dimensions as the existing browser window, the appearance that a 
5 normal navigate has occurred is maintained. The user is not aware of the creation of a 
new browser instance. In addition, because the new browser instance is created over the 
existing instance, the new browser instance can communicate via the HTML Document 
Object Model (DOM) with the existing browser instance, as required by most common 
applications that use browser open requests to open additional browser instances. 

10 Without this capability, a page would appear to function properly, but would not 
accomplish the task of communicating actions back to the page that opened it. 

Figure 2 is a flowchart depicting an example method 200 for processing a request 
to open a new browser instance, according to a particular embodiment of the present 
invention. First, as depicted at a block 202, the system receives a request to open a new 

1 5 browser instance. At a decision block 204, the system determines whether the request 
occurred during a navigate. If so, the request is assumed to have occurred automatically, 
without prior user input. Accordingly, the request is ignored at a block 206. 

If the request did not occur during a navigate, the system determines whether it 
occurred during the unloading of a page at a decision block 208. When a page begins a 

20 navigation, the first thing that occurs is the unloading of the current page. During this 
event, all browser open requests are ignored at a block 210. 

If the request occurred neither during a navigate nor during the unloading of a 
current page, it most likely occurred after the user clicked or pressed a key or keys on an 
element that can cause a navigation. After this point, all browser open requests are 

25 considered user initiated and are honored, as depicted at a block 2 1 2. 

Browser open requests are handled in this way in order to make them appear as 
full screen navigates. Handling browser open requests that occur before a user 
specifically clicks on an element to open a new page or that occur during a page's unload 
sequence would cause some pages to not be accessible to the user. For example, if a 

30 request to open a new browser instance occurring during the loading of a page were 

handled in-place, the user would not be able to interact with the page that generated the 
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request because the act of loading that page would cause the new browser instance to be 
loaded in its place. If the request occurs during the unloading of a page, the user would 
go to the page requested on unload, but would never get to the page that was targeted 
when the unload event initiated. Because these cases almost always occur in the context 
5 of advertisements, they are generally not critical to the user's web experience. To handle 
these requests properly, unload and load events are handled so that any browser open 
request that should be honored is honored only after the page has completed loading, but 
before new navigation has begun. That is, any new browser windows are opened only 
after all expected load requests are received, but before any unload events for the current 

1 0 page are received. 

In order to maintain the single-window interface, any browser open requests that 
are honored at block 212 are handled by opening a new, full-screen, instance of the 
browser directly over the existing instance, creating the appearance that a normal page 
navigate occurred. Further, any requests to open dialog boxes by browser instances that 

15 are not in the foreground are hidden until the applicable browser instance is in the 

foreground. Similarly, any sounds that would otherwise be emitted by browser instances 
in the background are not played. As a result, "bleed-through" of dialog boxes and 
sounds is avoided. 

In a particular embodiment, when a browser open request is honored, an 

20 additional instance of the browser is created, rather than handling the browser open 

request as a standard navigate request within the existing browser instance. On a desktop 
browser, a browser open request causes a second instance of the browser to be created in 
a separate thread. With the two browser instances running on separate threads, any 
JScript or VBScript calls from the first instance to the second instance are marshaled by 

25 COM. Some pages make use of inter-browser scripting to have events occurring in the 
first browser instance affect the content of the second browser instance. It should be 
noted that the WINDOWS CE® operating system does not support COM marshalling. 
Accordingly, in such an Internet appliance using the WINDOWS CE® operating system, 
both browser instances are run off a single thread, an approach that does not require 

30 COM marshalling, at the cost of a negligible performance tradeoff. In the Internet 
appliance environment, creating an additional browser instance allows the system to 
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maintain separate threads, e.g., for passing JScript calls from one browser instance to 
another, so that events occurring in one browser instance can affect the content of another 
browser instance. In environments with relatively limited memory resources, less 
recently opened browser instances are closed as necessary to free memory, keeping at 
5 least two browser instances open simultaneously so as to allow the proper functioning of 
the most common Internet pages making use of inter-browser communication between 
two pages. 

In the case of a page with multiple frames, a browser open request is only handled 
when either all the frames have finished loading, or after the frame from which the 

10 browser open request originated has finished loading. Accordingly, in a particular 

embodiment, the system is aware of which frame initiated a browser open request, as well 
as whether that frame has finished loading. In some cases, interface pointers that are 
passed when a browser open request is issued can be used to determine whether the frame 
from which the request issued is in the fully loaded state or not. 

1 5 Browser navigation is also handled in such a way as to preserve the appearance of 

a single-window interface. For example, a request from a browser instance to close itself, 
typically via a window.close() call, is handled by closing the browser instance and 
returning to the previous browser instance, unless no such previous browser instance 
exists. In this case, the request is ignored, as it would result in no browser instance being 

20 displayed. Likewise, any dialog boxes that give the user the option to close the browser 
are disabled. Even though such dialog boxes are still displayed, any requests to close the 
browser that issue from them are ignored. 

In addition, the browser history, i.e., the list that instructs the browser which page 
to go to when the back and forward browser buttons are pressed, keeps track of where 

25 browser transitions occur. This history list can be built from the current browser instance 
or from all browser instances. In the latter case, for example, if the back button is pressed 
on the first page of the current browser instance and a previous browser instance exists, 
the system hides the current browser instance and displays the previous instance. The 
user then sees the window transition from the first page of the current instance to the last 

30 page of the immediately preceding instance. 
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Figure 3 conceptually depicts an example series of navigation operations and the 
manner in which they are handled according to an operational example of the present 
invention. As illustrated in Figure 3, when building the browser history list across 
multiple instances, the current page on each browser instance is used as a reference point. 
5 In this operational example, the user first navigates to msnbc.com at a block 302. As 
denoted below block 302, the back history and forward history are both empty at this 
point. 

Next, at a block 304, the user navigates to microsoft.com, and the back history 
contains the entry msnbc.com. The forward history is still empty. At a block 306, the 

10 user uses the back button on the browser to navigate back to msnbc.com; the back history 
thus becomes empty again. The forward history contains the entry microsoft.com. 

At a block 308, the user clicks on a hyperlink that causes a browser open request 
to be issued for navigating to expedia.com. Although the page opens in a new window, 
the back history contains the entry msnbc.com, which was the page most recently visited, 

15 albeit from a different browser instance. The forward history associated with the new 
browser instance is empty. 

Finally, at a block 310, the user uses the back button on the browser to navigate 
back to msnbc.com. The back history thus becomes empty, since msnbc.com was the 
first page visited in this operational example. The forward history associated with this 

20 browser instance contains the entry expedia.com, the page visited immediately after (at 
block 308) the user visited msnbc.com at block 306. 

There are situations on the World Wide Web that can result in a user being 
"stuck" on - unable to navigate out of — a set of Web pages. For instance, a page may 
contain a navigate call that occurs while it is loading in order to redirect navigation to a 

25 more appropriate page. While this feature is useful in the case of, for example, outdated 
links, it also prevents the browser from navigating backwards past the page containing 
the navigate call. To address this issue, the navigate call is converted to a 
window. location.replace() call. As a result, navigation is still redirected to the more 
appropriate page, but the page that originated the navigate call is removed from the 

30 history list. Thus, the browser is able to navigate backwards past that page. 
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In one implementation, the system is embodied in an Internet appliance that has 
limited memory. As this memory fills up, the oldest browser instances in the history 
stream are removed down to the minimum limit. Once a browser open request has 
occurred, this minimum limit is two so that typical communication between browsers can 
5 occur. Typical communication involves one browser instance opening up another 
instance to perform some action and return the results of that action back to the parent 
browser instance. In a particular embodiment, a low-memory management scheme is 
used to pre-allocate a small block of memory for emergency purposes, such as deleting 
browser instances in the event of low memory. 

10 While the embodiments of the invention have been described with specific focus 

on their embodiment in a software implementation, the invention as described above is 
not limited to software embodiments. For example, the invention may be implemented in 
whole or in part in hardware, firmware, software, or any combination thereof. The 
software of the invention may be embodied in various forms, such as a computer program 

1 5 encoded in a machine-readable medium, such as a CD-ROM, magnetic medium, ROM or 
RAM, or in an electronic signal. Further, as used in the claims herein, the term "module" 
shall mean any hardware or software component, or any combination thereof. 
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What is claimed is: 



1 . In a computer system having a graphical user interface including a display 
and a user interface selection device, a method of maintaining a single window interface, 

5 comprising: 

receiving a request to open a second browser window while a first browser 
window is displayed; 

ignoring the request if the request was not initiated in response to a user action; 

and 

1 0 opening the second browser window if the request was initiated in response to a 

user action, 

2. The method of claim 1 ? further comprising opening the second browser 
window as a full-screen browser window if the request was initiated by a user action. 

15 

3 . The method of claim 2, further comprising superimposing the foil-screen 
browser window on the first browser window. 

4. The method of claim 1, further comprising opening the second browser 
20 window after receiving a load finished event for the first browser window and before 

receiving an unload event for the first browser window. 

5. The method of claim 1, further comprising opening the second browser 
window in a second browser instance distinct from a first browser instance in which the 

2 5 first browser window is op ened. 

6. The method of claim 5, further comprising modifying the content of one 
of the first and second browser windows in response to an event occurring in one of the 
first and second browser instances. 

30 
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7. The method of claim 1 , wherein the first browser window contains a 
plurality of frames, wherein the request to open a second browser window is associated 
with one of the plurality of frames, and wherein the method further comprises opening 
the second browser window after loading the frame associated with the request to open 

5 the second browser window. 

8 . The method of claim 7, further comprising opening the second browser 
window after loading all of the frames of the first browser window. 

10 9 . The method of claim 1 , further comprising suppressing a request to open a 

dialog box until a browser window associated with the request to open the dialog box is 
displayed. 

1 0. The method of claim 1 , further comprising suppressing generation of a 
1 5 sound associated with a browser window that is not displayed. 

1 1 . The method of claim 1 , further comprising: 
receiving a request to close a browser window; 

closing the browser window if another browser window is open; and 
20 ignoring the request if no other browser window is open. 

12. The method of claim 1 , further comprising maintaining, in a browser 
history, a history of transitions between the first and second browser windows. 

25 13. The method of claim 1 2, further comprising building the browser history 

from a history of a displayed browser window. 

14. The method of claim 1 2, further comprising building the browser history 
from histories of a set of simultaneously open browser windows. 

30 

1 5 . The method of claim 1 2, further comprising: 
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detecting, in the browser history, a transition between two simultaneously open 
browser windows; and 

in response to the detected transition, hiding one of the first and second browser 
windows and displaying a different one of the first and second browser windows. 

5 

16. In a computer system having a graphical user interface including a display 
and a user interface selection device, a method of maintaining a single window interface, 
comprising the steps of: 

receiving a request to open a second browser window while a first browser 
1 0 window is displayed; 

ignoring the request if the request was initiated during either loading or unloading 
of a page in the first browser window; and 

opening the second browser window if the request was initiated after loading and 
before unloading of a page in the first browser window. 

15 

17. The method of claim 1 6, further comprising opening the second browser 
window as a full-screen browser window if the request was initiated after loading and 
before unloading of a page in the first browser window. 

20 18, The method of claim 17, further comprising superimposing the full-screen 

browser window on the first browser window. 

19. The method of claim 1 6, further comprising opening the second browser 
window after receiving a load finished event for the first browser window and before 

25 receiving an unload event for the first browser window. 

20. The method of claim 16, further comprising opening the second browser 
window in a second browser instance distinct from a first browser instance in which the 
first browser window is opened. 
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2 1 . The method of claim 20, further comprising communicating information 
between the first and second browser windows in response to an event occurring in one 
of the first and second browser instances. 

22. The method of claim 16, wherein the first browser window contains a 
plurality of frames, wherein the request to open a second browser window is associated 
with one of the plurality of frames, and wherein the method further comprises opening 
the second browser window after loading the frame associated with the request to open 
the second browser window. 

23 . The method of claim 22, further comprising opening the second browser 
window after loading all of the frames of the first browser window. 



24. The method of claim 16, further comprising suppressing a request to open 
15 a dialog box until a browser window associated with the request to open the dialog box is 

displayed. 

25. The method of claim 16, further comprising suppressing generation of a 
sound associated with a browser window that is not displayed. 



10 



20 



25 



26. The method of claim 1 6, further comprising: 
receiving a request to close a browser window; 

closing the browser window if another browser window is open; and 
ignoring the request if no other browser window is open. 

27. The method of claim 1 6, further comprising maintaining, in a browser 
history, a history of transitions between the first and second browser windows. 



28. The method of claim 27, further comprising building the browser history 
30 from a history of a displayed browser window. 
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29. The method of claim 27, further comprising building the browser history 
from histories of a set of simultaneously open browser windows. 

30. The method of claim 27, further comprising: 

detecting, in the browser history, a transition between two simultaneously open 
browser windows; and 

in response to the detected transition, hiding one of the first and second browser 
windows and displaying a different one of the first and second browser windows. 

31. A computer-readable medium having stored thereon computer-executable 
modules comprising a browser module, configured to; 

receive a request to open a second browser window while a first browser window 
is displayed; 

ignore the request if the request was not initiated in response to a user action; and 
open the second browser window if the request was initiated in response to a user 

action. 

32. The computer-readable medium of claim 3 1 , wherein the browser module 
is further configured to open the second browser window as a full-screen browser 
window if the request was initiated by a user action. 

33. The computer-readable medium of claim 32, wherein the browser module 
is further configured to superimpose the full-screen browser window on the first browser 
window. 

34. The computer-readable medium of claim 31, wherein the browser module 
is further configured to open the second browser window after receiving a load finished 
event for the first browser window and before receiving an unload event for the first 
browser window. 



18 



35. The computer-readable medium of claim 3 1 , wherein the browser module 
is further configured to open the second browser window in a second browser instance 
distinct from a first browser instance in which the first browser window is opened. 

5 36. The computer-readable medium of claim 35, wherein the browser module 

is further configured to communicate information between the first and second browser 
windows in response to an event occurring in one of the first and second browser 
instances. 

10 37. The computer-readable medium of claim 3 1 , wherein the first browser 

window contains a plurality of frames, wherein the request to open a second browser 
window is associated with one of the plurality of frames, and wherein the browser 
module is further configured to open the second browser window after loading the frame 
associated with the request to open the second browser window. 

15 

38. The computer-readable medium of claim 37, wherein the browser module 
is further configured to open the second browser window after loading all of the frames 
of the first browser window. 

20 39. The computer-readable medium of claim 3 1 , wherein the browser module 

is further configured to suppress a request to open a dialog box until a browser window 
associated with the request to open the dialog box is displayed. 

40. The computer-readable medium of claim 3 1 , wherein the browser module 
25 is further configured to suppress generation of a sound associated with a browser window 

that is not displayed. 

41 . The computer-readable medium of claim 3 1 , wherein the browser module 
is further configured to: 

30 receive a request to close a browser window; 

close the browser window if another browser window is open; and 
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ignore the request if no other browser window is open. 

42. The computer-readable medium of claim 3 1 , wherein the browser module 
is further configured to maintain, in a browser history, a history of transitions between the 

5 first and second browser windows. 

43. The computer-readable medium of claim 42, wherein the browser module 
is further configured to build the browser history from a history of a displayed browser 
window. 

10 

44. The computer-readable medium of claim 42, wherein the browser module 
is further configured to build the browser history from histories of simultaneously open 
browser windows. 

15 45 . The computer-readable medium of claim 42, wherein the browser module 

is further configured to: 

detect, in the browser history, a transition between two simultaneously open 
browser windows; and 

in response to the detected transition, hide one of the first and second browser 
20 windows and displaying a different one of the first and second browser windows. 

46. A computer-readable medium having stored thereon computer-executable 
modules comprising a browser module, configured to: 

receive a request to open a second browser window while a first browser window 
25 is displayed; 

ignore the request if the request was initiated during either loading or unloading 
of a page in the first browser window; and 

open the second browser window if the request was initiated after loading and 
before unloading of a page in the first browser window. 

30 
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47. The computer-readable medium of claim 46, wherein the browser module 
is further configured to open the second browser window as a full-screen browser 
window if the request was initiated after loading and before unloading of a page in the 
first browser window. 

48. The computer-readable medium of claim 47, wherein the browser module 
is further configured to superimpose the full-screen browser window on the first browser 
window. 



1 0 49. The computer-readable medium of claim 46, wherein the browser module 

is further configured to open the second browser window after receiving a load finished 
event for the first browser window and before receiving an unload event for the first 
browser window. 



15 50. The computer-readable medium of claim 46, wherein the browser module 

is further configured to open the second browser window in a second browser instance 
distinct from a first browser instance in which the first browser window is opened. 

5 1 . The computer-readable medium of claim 50, wherein the browser module 
20 is further configured to communicate information between the first and second browser 
windows in response to an event occurring in one of the first and second browser 
instances. 



52. The computer-readable medium of claim 46, wherein the first browser 
25 window contains a plurality of frames, wherein the request to open a second browser 
window is associated with one of the plurality of frames, and wherein the browser 
module is further configured to open the second browser window after loading the frame 
associated with the request to open the second browser window. 
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53. The computer-readable medium of claim 52, wherein the browser module 
is further configured to open the second browser window after loading all of the frames 
of the first browser window. 

5 54. The computer-readable medium of claim 46, wherein the browser module 

is further configured to suppress a request to open a dialog box until a browser window 
associated with the request to open the dialog box is displayed. 

55. The computer-readable medium of claim 46, wherein the browser module 
1 0 is further configured to suppress generation of a sound associated with a browser window 

that is not displayed. 

56. The computer-readable medium of claim 46, wherein the browser module 
is further configured to: 

1 5 receive a request to close a browser window; 

close the browser window if another browser window is open; and 
ignore the request if no other browser window is open. 

57. The computer-readable medium of claim 46, wherein the browser module 
20 is further configured to maintain, in a browser history, a history of transitions between the 

first and second browser windows. 

58. The computer-readable medium of claim 57, wherein the browser module 
is further configured to build the browser history from a history of a displayed browser 

25 window. 

-59. The computer-readable medium of claim 57, wherein the browser module 
is further configured to build the browser history from histories of a set of simultaneously 
open browser windows. 

30 
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60. The computer-readable medium of claim 57, wherein the browser module 
is further configured to: 

detect, in the browser history, a transition between simultaneously open browser 
windows; and 

in response to the detected transition, hide one of the first and second browser 
windows and displaying a different one of the first and second browser windows. 

61. A computer system, comprising: 

a graphical user interface including a display and a user interface selection device; 

and 

a browser module, configured to 

receive a request to open a second browser window while a first browser 
window is displayed, 

ignore the request if the request was not initiated in response to a user 
action, and 

open the second browser window if the request was initiated in response to 
a user action. 



62. The computer system of claim 6 1 , wherein the browser module is further 
configured to open the second browser window as a full-screen browser window if the 
request was initiated by a user action. 



63. The computer system of claim 62, wherein the browser module is further 
configured to superimpose the full-screen browser window on the first browser window. 

64. The computer system of claim 61, wherein the browser module is further 
configured to open the second browser window after receiving a load finished event for 
the first browser window and before receiving an unload event for the first browser 
window. 
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65. The computer system of claim 61, wherein the browser module is further 
configured to open the second browser window in a second browser instance distinct 
from a first browser instance in which the first browser window is opened. 

5 66. The computer system of claim 65 ? wherein the browser module is further 

configured to communicate information between the first and second browser windows in 
response to an event occurring in one of the first and second browser instances. 

67. The computer system of claim 61, wherein the first browser window 
1 0 contains a plurality of frames, wherein the request to open a second browser window is 
associated with one of the plurality of frames, and wherein the browser module is further 
configured to open the second browser window after loading the frame associated with 
the request to open the second browser window. 

15 68. The computer system of claim 67 ? wherein the browser module is further 

configured to open the second browser window after loading all of the frames of the first 
browser window. 

69. The computer system of claim 61 , wherein the browser module is further 
20 configured to suppress a request to open a dialog box until a browser window associated 

with the request to open the dialog box is displayed. 

70. The computer system of claim 6 1 , wherein the browser module is further 
configured to suppress generation of a sound associated with a browser window that is 

25 not displayed. 

7 1 . The computer system of claim 6 1 , wherein the browser module is further 
configured to: 

receive a request to close a browser window; 
30 close the browser window if another browser window is open; and 

ignore the request if no other browser window is open. 
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72. The computer system of claim 6 1 , wherein the browser module is further 
configured to maintain, in a browser history, a history of transitions between a set of 
simultaneously open browser windows. 

5 

73. The computer system of claim 72, wherein the browser module is further 
configured to build the browser history from a history of a displayed browser window. 

74. The computer system of claim 72, wherein the browser module is further 
10 configured to build the browser history from histories of the set of simultaneously open 

browser windows. 

75. The computer system of claim 72, wherein the browser module is further 
configured to: 

1 5 detect, in the browser history, a transition between simultaneously open browser 

windows; and 

in response to the detected transition, hide one of the first and second browser 
windows and displaying a different one of the first and second browser windows. 

20 76. A computer system, comprising: 

a graphical user interface including a display and a user interface selection device; 

and 

a browser module, configured to 

receive a request to open a second browser window while a first browser 
25 window is displayed, 

ignore the request if the request was initiated during either loading or 
unloading of a page in the first browser window, and 

open the second browser window if the request was initiated after loading 
and before unloading of a page in the first browser window. 

30 
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77. The computer system of claim 76, wherein the browser module is further 
configured to open the second browser window as a full-screen browser window if the 
request was initiated after loading and before unloading of a page in the first browser 
window. 

5 

78. The computer system of claim 77, wherein the browser module is further 
configured to superimpose the full-screen browser window on the first browser window. 

79. The computer system of claim 76, wherein the browser module is further 
10 configured to open the second browser window after receiving a load finished event for 

the first browser window and before receiving an unload event for the first browser 
window. 

80. The computer system of claim 76, wherein the browser module is further 
1 5 configured to open the second browser window in a second browser instance distinct 

from a first browser instance in which the first browser window is opened. 

8 1 . The computer system of claim 80, wherein the browser module is further 
configured to communicate information between the first and second browser windows in 

20 response to an event occurring in one of the first and second browser instances. 

82. The computer system of claim 76, wherein the first browser window 
contains a plurality of frames, wherein the request to open a second browser window is 
associated with one of the plurality of frames, and wherein the browser module is further 

25 configured to open the second browser window after loading the frame associated with 
the request to open the second browser window. 

83. The computer system of claim 82, wherein the browser module is further 
configured to open the second browser window after loading all of the frames of the first 

30 browser window. 
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84. The computer system of claim 76, wherein the browser module is further 
configured to suppress a request to open a dialog box until a browser window associated 
with the request to open the dialog box is displayed. 

5 85. The computer system of claim 76, wherein the browser module is further 

configured to suppress generation of a sound associated with a browser window that is 
not displayed. 

86. The computer system of claim 76, wherein the browser module is further 
10 configured to: 

receive a request to close a browser window; 

close the browser window if another browser window is open; and 

ignore the request if no other browser window is open. 

15 87. The computer system of claim 76, wherein the browser module is further 

configured to maintain, in a browser history, a history of transitions between a set of 
simultaneously open browser windows. 

88. The computer system of claim 87, wherein the browser module is further 
20 configured to build the browser history from a history of a displayed browser window. 

89. The computer system of claim 87, wherein the browser module is further 
configured to build the browser history from histories of the set of simultaneously open 
browser windows. 

25 

90. The computer system of claim 87, wherein the browser module is further 
configured to: 

detect, in the browser history, a transition between simultaneously open browser 
windows; and 

30 in response to the detected transition, hide one of the first and second browser 

windows and displaying a different one of the first and second browser windows. 
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ABSTRACT OF THE DISCLOSURE 

In a single window browser environment, a request to open a new browser 
window is either allowed or ignored, depending on whether the request was generated in 
response to user input. The request is ignored if it was not generated in response to user 

5 input. If, on the other hand, the request was generated in response to user input, it is 

allowed. In such cases, in order to preserve the single window interface, the new browser 
window is opened as a full screen window that overlays the existing browser window. In 
certain implementations, the determination of whether or not a request was generated in 
response to user input is simplified by assuming that all requests that are generated during 

10 the loading or unloading of a page are not in response to user input and ought to be 
ignored. By contrast, window open requests that are generated at other times are 
assumed to be user-initiated and are allowed. 
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